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THE LOW-COST KEYBOARD, LIKE THE 
majority Of other typewriter style key- 
boards, provides only a single “make” 
contact for each key depressed (see 
Radio-Electronics, February 1973). 
Computer terminals. teaching ma- 
chines. etc., cannot directly use a 
single-contact operation, and a device 
called an encoder must be placed be- 
tween the keyboard and the computer. 
The encoder converts the single con- 
tact closure into a seven- or eight-bit 
IC logic compatible parallel code, usu- 
ally following the ASCII encoding 
scheme, and allowing for shift and 
control key operations. After parallel 
encoding. there may follow a purity 
generator for error detection, and a 
100-word-per-minute paralle! to serial 
converter that allows the signals to be 
sent down a single wire or phone linc. 

The keyboard encoder described 
here costs only a tiny fraction of com- 
mercial equivalents. It uses three “dol- 
lar” integrated circuits and a small 
handful of surplus computer diodes. 
While this encoder was designed us a 
companion to the low-cost keyboard. 
it may be used with any keyboard, 
provided the make contacts are less 
than 2000 ohms when ON and pro- 
vided that the keys do nor have a 
common ground terminal. The en- 
coder generates all the codes shown in 
Table {. This includes all the capital 
letters, all the often used punctuation, 
all numerals, and all of the trans- 
parent or control functions. Often 
used control functions such as DELETE, 
SPACE, LINE FEED, ESCAPE (ALT MODE), 
CARRIAGE RETURN, etc. are brought 
out to separate keys. The output is 
RTL. TTL, DTL and MOS com- 
patible. and a single 10-volt, 25-mA 
power source is needed, If an ASCII 


build an 
3 ASCII 


keyboard 
encoder 


Here is what you need to couple the key- 


board you built in February to a computer, 
teletype, or teaching machine. 


by DON LANCASTER 


code is not desirable, the same en- 
coder may be used. through suitable 
rewiring. to generate EBDIC. SELECTRIC, 
BAUDOT Or MORSE codes. Parity and 
the 100-wpm (words-per-minute) serial 
converter are easily added to the basic 
encoder. 


What is the ASCII code? 

Many years ago, the American 
Stundards Association decided to 
adopt a standard code that computers 
could use to talk to each other, to 
their input/output devices, and to al- 
low standardized connections between 
different brands of computer ma- 
chinery. The resultant industry wide 
code is called ASCII, short for A meri- 
can Standard Code tor /nformation 
/nterchange. This code is a sequence 
of six, seven, or eight bits (ones or 
zeros). It may be sent either in serial 
(bit by bit, least significant bit first) 
form, or in parallel (all bits at once, 
on 6, 7, or 8 lines) form. Usually. par- 
allel words are used inside machines, 
while serial words are used between 
machines. Serial words are obviously 
slower, but they take far less wire and 
interconnections. 

The basic code consists of seven 
bits. If we look at all possible combi- 
nations of seven ones and zeros from 
000-0000, 000-0001 through to 

_ TTI-IULL, we'd tind a total of 128 
different sequences. Each of these may 
be used to represent something dis- 
tinct. 64 of these code sequences are 
used for alphanumeric capital letters. 
numbers, a blank, and punctuation. 32 
more sequences are used for srans- 
parent or control commands that never 
appear On a Screen or in print. These 
commands tell the machinery on the 
other end what to do—things like re- 
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turning carriages, clearing. line feeds, 
bell ringing. and other control ftunc- 
tions, A final 32-code sequences are 
reserved for lower case alphabet and 
some little used punctuation. This last 
group is very seldom used as most 
computer communications can be han- 
dled with only capital letters, numer- 
als, control commands, and common 
punctuation. 

The complete code appears in 
Table II. It is arranged in a mazrtx 
form to make it compact and easy to 
read. For instance, the transparent 
command “Carriage Return”, or “CR” 
has a code of 000-1101, starting with 
bit 7 on the left and going to bit | 
(the least significant) on the right. A 
numeric “6” has the code 011-0110. 
Note the right half of this code is the 
Same as a binary or a binary-coded- 
decimal six. A capital L has the code 
100-1100, while the lower case L is a 
110-1100. 

There are several ways to use the 
code, depending on how much you 
want the code to do. If we are only 
interested in upper-case alphabet, nu- 
merics, and punctuation, we can use 
the middle of the code and get by 
with a six-bit code, sometimes called 
ASCII-6. This is useful in character 
generators and displays that do not 
need transparent commands or lower 
case alphabets. Many MOS integrated 
circuits are now available that convert 
the six-bit subset into a recognizable 
bunch of dots on a TV screen or a 
line printer; these are called ASCII 
Character Generators. 

Or, we can use all seven bits, ei- 
ther with or without the lower case 
stuff, picking up both alphanumerics 
and control commands. This is often 
called the ASCII-7 code. Finally. if we 
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TABLE | OUTPUT CODES 


The output codes below are shown 
in HEXADECIMAL notation to conserve 
space. Thus “3D” is an ASCII 011-1101, 
or output a, =1, ay=O0, ag=1, etc... . 


The ‘Key Depressed” output does NOT 


NORMAL 
CODE 


40 
41 
42 
43 


xz 
m 
< 


QODn>re 


44 
45 
46 
47 


onmo 


48 
49 
4A 
4B 


Xe-.L 


4c 
4D 
4E 
4F 


O2Z=S=r 


50 
51 
52 
53 


oDOnv 


54 
55 
56 
57 


S<c-i 


58 
59 
5A 


N < >< 


30 
31 
32 
33 


wnm + Oo 


4 34 
5 35 
6 36 
7 37 


8 38 
9 39 


3A 
3B 


2c 
6 2D 
> 2E 
? 2F 


A 


4 SE 

a 5F 
SPACE 20 
LINEFEED 0A 
C. RETURN 0D 
ESCAPE (ALT) 1B 


DELETE 7F 


ei 


appear for the SHIFT Or CONTROL buttons 
depressed separately. All other keys, 
whether or not they are used with SHIFT 
Or CONTROL, produce a Key Depressed 
output. 


~ SHIFTED CONTROL 


CODE ; CODE 
40 00 (null) 
41 01 (soh) 
42 02 (stx) 
43 03 (etx) 
44 04 (eot) 
45 05 (eng) 
46 06 (ack) 
47 07 (bell) 
48 08 (bs) 
49 09 (ht) 
4A OA (Lf) 
4B OB (vt) 
4c OC (FF) 
4D OD (cr) 
4E OE (so) 
4F OF (si) 
50 10 (dle) 
51 11 (DC1) 
52 12 (DC2) 
53 13 (DC3) 
54 14 (DC4) 
55 15 (NAK) 
56 16 (SYN) 
57 17 (ETB) 
58 18 (CAN) 
59 19 (EM) 
5A 1A (SUB) 
20 (space) 10 (dle) 
21 (!) 11 (DC1) 
22 (") 12 (DC2) 
23 (=) 13 (DC3) 
24 ($) 14 (DC4) 
25 (%) 15 (NAK) 
26 (&) 16 (SYN) 
27 (') 17 (ETB) 
28 (—) 18 (CAN) 
29 ()) 19 (EM) 
2A (*) 1A (SUB) 
2B (+) 1B (ESC) 
3C (,) OC (ff) 
3D (-) OD (cr) 
3E (.) OE (so) 
SF (/) OF (si) 
5E— 1E (rs) 
5F 1F (us) 
20 00 (null) 
0A OA (Lf) 
0D OD (cr) 
1B 1B (esc) 
7F 1F (si) 
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like, we cun add an eighth bit and use 
it for error detecting. It is called the 
parity bit. In an even parity system, the 
parity bit makes the total number of 
ones in the word even. If there are | 
3. 5, or 7 ones in the word before the 
parity bit is added. the parity bit is a 
one. If there are 0. 2. 4. or 6 ones. the 
parity bit is a zero. This way, there is 
always an even number of ones sent. 
Alt the receiving end, paritv is once 
again tested. If an odd number of 
ones shows up. a mistake has been 
made. and the receiver can substitute 
a ©? or ask for the information over 
again. We could also use an odd par- 
ity system just as well. provided both 
ends are playing the game with the 
same rules. This is called the ASCII-8 
code. 

Seven bits are rarely sent between 
machines. An eighth wire or bit space 
is usually added, so that if parity is 
added later, it doesn’t take a bunch of 
rework. Similarly. most paper tape 
punches and magnetic tape is in an 
eight-track code: if parity isn’t used, 
the eighth bit 18 usually all ones. 

You may wonder what all those 
transparent commands stand for. Ac- 
tually. a lot of them are only used on 
very big and very complicated ma- 
chines, and thus aren’t really very 
common. The ones you'll probably use 
are few in number. For instance. CR 
iS a carriage return that staris a new 
line on a typewriter. LF is the line 
feed. used to skip a line. BEL rings a 
bell or signals an operator. BS is 
backspace. It can only be used in 
some systems. for many CRT termi- 
nals and teletypes cannot back up. 
The direct control commands are la- 
beled DC/. DC2. DC3. and DC. 
These are usually yours to do any- 
thing you want with. such as turning 
on and off equipment, remote signall- 
ing, ete. NUL is a do-nothing com- 
mand that everything sits in while not 


ASCII ENCODER PARTS LIST 


‘R1—390 ohms, % watt (sets operating force— 
see text) 

R2, R3, R4—100,000 ohms, % watt 

R5, R7, R10, R16—4700 ohms, % watt 

R6, R8, RY, R11, R12. R13, R14—9100 ohms 
Y% watt 5% 

R15—470 ohms, % watt 

R17, R18, R19—100 ohms, % watt 

R20—2200 ohms, % watt 

R21, R22, R23—10,000 ohms, % watt 

C1—0.1-F disc ceramic capacitor 

C2, C3—100-uF 10V electrolytic 

01 thru O26—1N914 or similar silicon com- 
puter diode 

027—1N4736 or similar 6.8-V Zener diode 

1C1, 1C2, IC3—MC 9818P mwrtl hex inverter 

Q1. Q5, Q6, Q7—2N5139 pnp transistor 

Q2, Q3, Q4, Q8B—2N5129 npn transistor 

MISC: PC board. jumpers, sleeving, solder. 
hardware 


in use. Finally, ESC is called Escape 
or Alternate mode. This lets vou break 
out of the ASCII code if you ever 
need a longer sequence or something 
else special. The technique is called 
code extension. One common use is on 
a timesharing terminal. where you can 
switch back and forth between BASIC. 


guages using the ESC or exactly 
equivalent ALT key. 

DEL is a II-III] code that’s 
used to delete a previous command or 
fill a paper tape full of holes. 


Construction steps 
The schematic and parts list is 


ranged electrically to form an “8 x 8" 
array, and pnp transistors translate the 
positive end ef the array back down 
to logic levels. This technique requires 
far fewer diodes than a direct encod- 
ing does. The conrro! and shift keys 
suitably alter the code of only those 
keys they're supposed to change. 


FORTRAN. and EXECUTIVE MODE lan- shown in Fig. |. The keys are ar- A printed circuit board is used for 
1C1-3 
MC9BI8P 


! 
| | 
| | 
l l 
fl l 
| | 
| | 
| | 
| | 
| | 
sine — aaa r 


Pp 
Q3-Q4 027 ee 


2N5129 


ESC 
el fel O28 = 
oe OA 3 I 
H-0 © i al D26 
@-G = D1, 
ella 
X-2 0 | 
P-W o 
PYNY YY nm | Yon § i 
cy ae ae oa? 
O00 getters 
alle. Don 
010 
¥ R17 1002 0 a6 
0110 <f 
100 6 eRe R18 
10022 
oreo k 
1100 
R19 
11 oem 1002. 
* 
t Q5-7 
INPUTS 2N5I39 | ge 
| 
D1-26 | 
INSI4 | 
i. ) R22 | 
“7 "ark 10K oe 
100K és ; 
a) 2N5129 a, 
t pa Ss, l 
~ 100K R23 io, 
{ boos 10K | 
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FIG. 1—SCHEMATIC DIAGRAM OF THE ENCODER shows how simple the device can be when 
three Inexpensive IC's are used. 
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assembly. [Us available commercially 
(see Fig. | parts list) or you can make 
your own using the pattern in Fig. 2 
and following the drilling and assem- 
bly guides of Figs. 3 and 4. Use a 
small iron and fine solder for assem- 
bly. and be careful to observe the 
code notch and dot on the IC’s and 
the polarity bands on the diodes and 
capacitors. 

Resistor R} determines the oper- 
ating force required on the keyboard. 
It is chosen to be low enough in value 
that each key’s output code is set up 
and correct at 4 to % the pressure re- 
quired to get the “key pressed” output 
command. This way the code is set up 
and stable before it is sent. Capacitor 
C3 further delays the “go” command 
to insure reliable operation. Be sure 
you use only the leading edge of the 
“key pressed” command, for it lasts 


#24SOLID JUMPER COMPONENT 
SIDE (5) 


360 DRILL 


TREQ'D 


’ TABLE I! COMPLETE ASCII CODE 


2 eC MATL 
16 


To read the* matrix, choose your 
character. Then read the three high or- . 
der bits off the top and the four low Of- - 
dér bits off the left side. For instance, a. 
small alphabet "‘f" is a binary .110-0110, 
ever wne knowh: a8 a’ hexadecimal 66.” .. 


longer than the rest of the code does. 
Should a second key be pressed be- 
fore the first one is released, it’ will 
not be sent. giving a form of “2 key 
rollover” protection. 

The PC board mounts on short 
spacers directly below the keyboard, 
and connects to the keyboard with a 


FIG. 3 (left)—DRILL 
GUIDE for the PC 
board. Solid-wire 
jumpers are on the 
component side. 


FIG. 4 (rlght)N—COMPONENT 
SIDE of the encoder board. 
Jumpers are shown here as 
well as in Fig. 3 at left. 


; o 


FIG. 5—PARITY GENERATOR for the eighth 
bit (aB) needs only one IC for odd or even 
Parity. 


Each control function has a specific 
meaning. For instance. “LF” stands for a 
line. feed, “CR” is a carriage return, 
“BEL”. is a bell, to attract an operator’s 
attention,-.“ESC” is’an’ escape for-com- 
plicated cohtrol instructions, etc. . > 
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ye ENCODER 


he et erty 


double connector, a flat cable, or di- 
rect jumpers. An Amphenol 1[43-012- 
Ol connector may be used as an out- 
put. A [2-volt supply may be used by 
going to an 8-volt’ Zener diode. Op- 
eration at 5S or 6 volts may be ob- 
tained by lowering all the resistors, 
but the required keyforce will be 


~f de, 
Rt? SHIFT 
t at 
ee i 
“Ft 
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CRLF | 
DIISPACE . 
WO 
ae | gO 
2° er 
oe 
4p 000° 
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ojo Os; 
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og Ne 
AOL 
ms} 
le 
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5(EVEN) 
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PARITY 
GENERATOR 
1] 8] Sfiojitiait3 L a8 
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OUTPUTS 


4 © a6 
~ = - 
o 2 a4 


FROM ENCODER 


100-WPM ADAPTOR PARTS LIST 

R1—1000 ohms, % watt 
R2—2200 ohms. % watt 
R3—10 ohms, % watt 
R4—10,000 ohms, % watt 
R5—potentiometer, 1000 ohms, linear 
C1—0.1-F 10V disc ceramic 
C2, C3—100-uF 6V electrolytic 
C4—4-nF 10V tantalum, 10% 
D1—1N4002 silicon power diode or equal 
1C1—MC4024 TTL multivibrator 
IC2—SN74165 TTL 8-bit shift register. PISO 
IC3—SN7474 TTL dual-type-D flip-flop 
Q1—2N1613 npn silicon transistor 
MISC: PC board, jumpers, sleeving, mounting 

adaptor hardware. 


greater and less uniform from key to 
key. TTL (Transistor Transistor Logic) 
fanout is | standard load. RTL (Resis- 
tor Transistor Logic) tanout 
medium-power gate. 


is one 


proper codes in Table I. It’s partic- 
ularly important to watch all the bits 
at once with lamp drivers, IC testers, 
or something similar during initial 
checkout to be sure the code is up 


The unit is tested by noting the 


and stable betore the keypressed com- 


Le 
— 43" ______-—---__+ 


FIG. 2—FOIL PATTERN FOR THE ENCODER PC BOARD. This board mounts just below the key- 
board and connects to It through flat cable, PC connectors or direct wired Jumpers. 
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FROM ENCODER 


+5V 


“P.1.S.0- PARALLEL tN OR 
SERIAL OUT PARITY GENERATOR 


FIG. 6—TELETYPE FEED Is through a special adapter circuit. This one handles up to 100 words 
per minute. A precision oscillator controls the storage and output from the shift register. 
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mand is sent tor each and every key. 
An optional parity generator for 
the eighth bit is shown in Fig. 5 and 
may be used for even or odd parity. A 
100 word per minute teletype adaptor 
is shown in Fig. 6. The 1!00-wpm 
adapter consists of an oscillator whose 
period must be exactly 9.09 ms. Upon 
the Key Pressed command, an ASCII 
code, a START bit and a SYNCHRO- 
NIZING bit are loaded into a parallel- 
load shift register. After loading is 
completed, the oscillator marches out 
the code bits in proper sequence to be 
teletype and computer compatible. 
The circuit may accept a second char- 
acter anytime after the 110-ms trans- 
mission time. The output consists of a 
transistor that normally shorts the tele- 
type line. lt breaks the line anytime a 
“I’ is to be transmitted. The proper 
polarity must be observed on the out- 
put, and the 20 or 30 mA loop current 


source is located elsewhere. R-E 
CIRCUIT BREAKER 
SUBSTITUTION BOX 

A substitution box with circuit 


breakers selected by a switch is one of 
the handiest gadgets on my _ service 
bench. With breakers of different rat- 
ings, I’m ready to check radios, ampli- 
fiers and TV’s with blown fuses and 
questionable circuit breakers. 

Generally, I can clip onto the 
fuse or circuit breaker if the chassis 
has been pulled. I’ve rigged up a 
handy adapter that lets me jump fuses 
without pulling the chassis when the 
fuse holder is a post type on a panel 
or chassis skirt. The drawing shows its 
construction. 

Drill a % inch hole through the 


BLOWN GLASS FUSE 


HOOK-UP 


TO CLIPS 


center of a spare fuse-holder cap. Drill 
small holes slightly off center in the 
ends of a blown cartridge fuse. Drill a 
second hole, just large enough to pass 
a piece of thin insulated hook-up 
wire, in the center of one end of the 
fuse. Strip about % inch of insulation 
off one end of a piece of hook-up 
wire and pass it through the center of 
the fuse so the short exposed wire 
goes through the hole in the far end. 
Solder. Solder a second piece of hook- 
up wire to the other end and then 
thread both leads through the fuse- 
post cap and then add clips for con- 
necting to the breaker substitution 
box.—Arthur M. Padmore R-E 
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